<template>
  <div class="edit-popup">
    <popup
        ref="popupRef"
        :title="popupTitle"
        :async="true"
        width="550px"
        @confirm="handleSubmit"
        @close="handleClose"
    >
      <el-form label-position="left" ref="formRef" :model="formData" label-width="84px" :rules="formRules">
        <el-form-item label="名称" prop="name">
          <el-input v-model="formData.name" placeholder="请输入名称" clearable/>
        </el-form-item>
        <!-- 账号输入框 -->
        <el-form-item label="账号" prop="account">
          <el-input
              v-model="formData.account"
              :disabled="formData.root == 1"
              placeholder="请输入账号"
              clearable
          />
        </el-form-item>
        <!-- 管理员头像 -->
        <el-form-item label="头像" prop="avatar">
          <div>
            <div>
              <material-picker v-model="formData.avatar" :limit="1"/>
            </div>
            <div class="form-tips">建议尺寸：100*100px，支持jpg，jpeg，png格式</div>
          </div>
        </el-form-item>
        <!-- 密码输入框 -->
        <el-form-item label="密码" prop="password">
          <el-input
              v-model="formData.password"
              show-password
              clearable
              placeholder="请输入密码"
          />
        </el-form-item>

        <!-- 确认密码输入框 -->
        <el-form-item label="确认密码" prop="password_confirm">
          <el-input
              v-model="formData.password_confirm"
              show-password
              clearable
              placeholder="请输入确认密码"
          />
        </el-form-item>

        <template v-if="mode !== 'edit'">

          <!-- 角色选择框 -->
          <el-form-item label="角色" prop="role_id">
            <el-select
                v-model="formData.role_id"
                :disabled="formData.root == 1"
                class="flex-1"
                placeholder="请选择角色"
                clearable
                @change="roleChange"
            >
              <el-option v-if="formData.root == 1" label="系统管理员" :value="0"/>
              <el-option
                  v-for="(item, index) in optionsData.role"
                  :key="index"
                  :label="item.name"
                  :value="item.id"
              />
            </el-select>
          </el-form-item>

          <el-form-item label="绑定用户" prop="user_id">
            <el-select v-model="formData.user_id">
              <el-option v-for="(item,index) in userList" :value="item.id" :label="item.name" :key="index"/>
            </el-select>
          </el-form-item>

          <!-- 名称输入框 -->
          <el-form-item label="归属部门" prop="dept_id">
            <el-tree-select
                class="flex-1"
                v-model="formData.dept_id"
                :data="optionsData.dept"
                clearable
                multiple
                node-key="id"
                :props="{
                            value: 'id',
                            label: 'name',
                            disabled(data: any) {
                                return data.status !== 1
                            }
                        }"
                check-strictly
                :default-expand-all="true"
                placeholder="请选择上级部门"
            />
          </el-form-item>

          <el-form-item label="岗位" prop="jobs_id">
            <el-select
                class="flex-1"
                v-model="formData.jobs_id"
                clearable
                multiple
                placeholder="请选择岗位"
            >
              <el-option
                  v-for="(item, index) in optionsData.jobs"
                  :key="index"
                  :label="item.name"
                  :value="item.id"
              />
            </el-select>
          </el-form-item>

          <!-- 管理员状态 -->
          <el-form-item label="管理员状态" v-if="formData.root != 1">
            <el-switch v-model="formData.disable" :active-value="0" :inactive-value="1"/>
          </el-form-item>
          <!-- 多处登录 -->
          <el-form-item label="多处登录">
            <div>
              <el-switch
                  v-model="formData.multipoint_login"
                  :active-value="1"
                  :inactive-value="0"
              />
              <div class="form-tips">允许多人同时在线登录</div>
            </div>
          </el-form-item>
        </template>
      </el-form>
    </popup>
  </div>
</template>
<script lang="ts" setup>
import type {FormInstance} from 'element-plus'
import Popup from '@/components/popup/index.vue'
import {useDictOptions} from '@/hooks/useDictOptions'
import {adminAdd, adminDetail, adminEdit} from '@/api/perms/admin'
import {roleAll} from '@/api/perms/role'
import {jobsAll} from '@/api/org/post'
import {deptAll} from '@/api/org/department'
import {getAllGuideUser, getAllShopUser} from '@/api/person'

const emit = defineEmits(['success', 'close'])
const formRef = shallowRef<FormInstance>()
const popupRef = shallowRef<InstanceType<typeof Popup>>()
const mode = ref('add')
const popupTitle = computed(() => {
  return mode.value == 'edit' ? '编辑管理员' : '新增管理员'
})
const formData = reactive({
  id: '',
  account: '',
  name: '',
  dept_id: [],
  jobs_id: [],
  role_id: '',
  avatar: '',
  password: '',
  password_confirm: '',
  disable: 0,
  multipoint_login: 1,
  root: 0,
  user_id: '',
})
const passwordConfirmValidator = (rule: object, value: string, callback: any) => {
  if (formData.password) {
    if (!value) callback(new Error('请再次输入密码'))
    if (value !== formData.password) callback(new Error('两次输入密码不一致!'))
  }
  callback()
}


const userList = ref([])

async function roleChange(ev: any) {
  formData.user_id = ''
  let reqFunc: any = null
  if (ev === 3) {
    // 商家
    reqFunc = getAllShopUser
  }
  if (ev === 2) {
    // 导游
    reqFunc = getAllGuideUser
  }
  userList.value = await reqFunc()!
}

const formRules = reactive({
  account: [
    {
      required: true,
      message: '请输入账号',
      trigger: ['blur']
    }
  ],
  name: [
    {
      required: true,
      message: '请输入名称',
      trigger: ['blur']
    }
  ],
  role_id: [
    {
      required: true,
      message: '请选择角色',
      trigger: ['blur']
    }
  ],
  password: [
    {
      required: true,
      message: '请输入密码',
      trigger: ['blur']
    }
  ] as any[],
  password_confirm: [
    {
      required: true,
      message: '请输入确认密码',
      trigger: ['blur']
    },
    {
      validator: passwordConfirmValidator,
      trigger: 'blur'
    }
  ] as any[],
  avatar: [
    {
      required: true,
      message: '请上传头像',
      trigger: 'change',
    }
  ] as any[],
  user_id: [
    {
      required: true,
      message: '请绑定用户',
      trigger: 'change'
    }
  ] as any[]
})
const {optionsData} = useDictOptions<{
  role: any[]
  jobs: any[]
  dept: any[]
}>({
  role: {
    api: roleAll
  },
  jobs: {
    api: jobsAll
  },
  dept: {
    api: deptAll
  }
})

function getPayload() {
  const {role_id} = formData
  let result: any = role_id
  if (!Array.isArray(role_id)) {
    result = [role_id]
  }
  return {
    ...formData,
    role_id: result
  }
}

const handleSubmit = async () => {
  await formRef.value?.validate()
  const payload = getPayload()
  mode.value == 'edit' ? await adminEdit(payload) : await adminAdd(payload)
  popupRef.value?.close()
  emit('success')
}

const open = (type = 'add') => {
  mode.value = type
  popupRef.value?.open()
}

const setFormData = async (row: any) => {
  formRules.password = []
  formRules.password_confirm = [
    {
      validator: passwordConfirmValidator,
      trigger: 'blur'
    }
  ]
  const data = await adminDetail({
    id: row.id
  })
  for (const key in formData) {
    if (data[key] != null && data[key] != undefined) {
      //@ts-ignore
      formData[key] = data[key]
    }
  }
}

const handleClose = () => {
  emit('close')
}

defineExpose({
  open,
  setFormData
})
</script>
